package cn.com.datasource;

import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;

/**
 * @author liufl E-mail:Huberier@allpyra.com
 * @version 创建时间：2017年8月1日 下午6:32:04 类说明
 */
@Aspect
@Order(-10)// 保证该AOP在@Transactional之前执行
@Component
public class DynamicDataSourceAspect {

	/*
	 * 
	 * @Before("@annotation(ds)")
	 * 
	 * 的意思是：
	 * 
	 * 
	 * 
	 * @Before：在方法执行之前进行执行：
	 * 
	 * @annotation(targetDataSource)：
	 * 
	 * 会拦截注解targetDataSource的方法，否则不拦截;
	 */

	@Before("@annotation(targetDataSource)")
	public void changeDataSource(JoinPoint point,TargetDataSource targetDataSource) throws Throwable {

		// 获取当前的指定的数据源;

		// 如果不在我们注入的所有的数据源范围之内，那么输出警告信息，系统自动使用默认的数据源。
		try{
			System.out.println("UseDataSource : {} > {}"+ targetDataSource.value() + point.getSignature());
			// 找到的话，那么设置到动态数据源上下文中。
			DynamicDataSource.setDatabaseType(targetDataSource.value());
		}catch(Exception e){
			System.err.println("数据源[{}]不存在，使用默认数据源 > {}"+ targetDataSource.value() + point.getSignature());
		}
	}

	@After("@annotation(targetDataSource)")
	public void restoreDataSource(JoinPoint point,TargetDataSource targetDataSource) {
		System.out.println("RevertDataSource : {} > {}"+ targetDataSource.value() + point.getSignature());
		// 方法执行完毕之后，销毁当前数据源信息，进行垃圾回收。
		DynamicDataSource.clearDatabaseType();
	}

}
